<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #box1{
            width: 200px;
            height: 200px;
            background-color: skyblue;
        }
        #s1{
            background-color: yellow;
        }
    </style>
    <script>
        window.onload=function(){
            /*
                事件的冒泡(Bubble)
                    -所谓的冒泡指的就是事件的向上传导，当后代元素上的事件被触发时，其祖先元素的相同事件也会触发
                    -在开发中大部分冒泡是有用的，如果不希望发生事件冒泡可以通过事件对象来取消冒泡
            */
            //为s1绑定一个单机响应函数
            var s1=document.getElementById("s1");
            s1.onclick=function(event){
                event=event || window.event;
                alert("我是span的单机响应函数");
                //取消冒泡
                event.cancelBubble=true;
            }
            //为box1绑定一个单机响应函数
            var box1=document.getElementById("box1");
            box1.onclick=function(event){
                event.cancelBubble=true;
                alert("我是div的响应函数");
            }
            //为body绑定一个单机响应函数
            document.body.onclick=function(event){
                event.cancelBubble=true;
                alert("我是body的单机响应函数");
            }
        }
    </script>
</head>
<body>
    <div id="box1">
        我是Box1
        <span id="s1">我是span</span>
    </div>
</body>
</html>